草庐IT

php - Mongodb查询问题

全部标签

ruby-on-rails - 将 bool 值传递给 update_attributes 的问题

我有以下模型:classGuestCateringtruevalidates:order_number,:presence=>truevalidates:orderable,:presence=>trueend但是当我尝试使用以下代码更新现有的GuestCatering时:guest_catering.update_attributes(:orderable=>false)guestcatering变量是一个有效的GuestCatering对象。guest_catering对象更新后出现错误,像这样:nil}>但是当我传递一个orderable=>true时,一切都很好,没有错误。这里

sql - 通过关联的 Rails 查询仅限于最近的记录?

classUserhas_many:books我需要一个返回的查询:最近一本书具有:complete=>true的用户。即,如果用户最近的书有:complete=>false,我不希望它们出现在我的结果中。到目前为止我有什么User.joins(:books).merge(Book.where(:complete=>true))这是一个很有希望的开始,但没有给我需要的结果。我试过添加.order("created_ondesc").limit(1)到上述查询的末尾,但是当我期待很多结果时,我最终只得到一个结果。谢谢! 最佳答案 如果

ruby-on-rails - Rails ActiveRecord 查询日期范围

我正在尝试在我的Controller中使用以下行来捕获从当前日期起不到一周的所有任务:@due_this_week=current_user.tasks.where(due_date:Date.today..1.week.from_now)出于某种原因,它没有找到任何结果,即使我知道我有四到六天的任务到期。这是唯一使用范围查询的实例变量。我有另一个可以很好地查找逾期任务的工具:@overdue=current_user.tasks.where("due_date我错过了什么? 最佳答案 应该是:@due_this_week=curr

ruby-on-rails - Ruby:在 Windows 7 下安装 EventMachine 时出现问题

我正在尝试通过捆绑在Windows7上安装gemEventMachine(使用Ruby1.9.2和RubyInstaller),但出现以下错误。我还安装了DevKit,它可以正常工作,但我仍然无法弄清楚问题是什么:Installingeventmachine(0.12.10)withnativeextensionsC:/Ruby192/lib/ruby/site_ruby/1.9.1/rubygems/installer.rb:551:in`rescueinblockinbuild_extensions':ERROR:Failedtobuildgemnativeextension.(G

ruby-on-rails - ActiveRecord 查询中的 “includes” 和 “preload” 有什么区别?

我正在努力寻找ActiveRecord对象的includes()和preload()的比较。谁能解释一下区别? 最佳答案 Rails有两种方法可以避免n+1问题。一个涉及创建一个基于大连接的查询以拉入您的关联,另一个涉及为每个关联进行单独的查询。当您执行includes时,rails会决定为您使用哪种策略。它默认使用单独的查询方法(预加载),除非它认为您正在使用条件或订单中关联的列。因为这只适用于joins方法,所以改用它。Rails的启发式方法有时会出错,或者您可能有特定的原因偏爱一种方法而不是另一种方法。preload(及其配套

ruby-on-rails - Ruby/Rails - 用两个词命名的模型(命名约定问题)

这真的是一个关于命名约定的问题。我有一个名为PromotedEvents的模型该文件名为promoted_events.rb我创建了这个表:create_table:promoted_eventsdo|t|现在我在创建任何东西时都遇到了问题,所以我想知道使用带有两个词的模型是否存在问题我在控制台中尝试了a=PromotedEvents.newa=Promoted_Event.newa=promoted_event.new并不断收到nameerror:uninitializedconstant错误有什么想法吗? 最佳答案 你的类(cl

ruby-on-rails - 是否有与 PHP 的 isset() 等效的 Rails?

基本上只是检查以确保设置了url参数。我如何在PHP中做到这一点:if(isset($_POST['foo'])&&isset($_POST['bar'])){}这是RoR中isset()的粗略/最佳等价物吗?if(!params['foo'].nil?&&!params['bar'].nil?)end 最佳答案 更接近的匹配可能是#present?#returnstrueifnotnilandnotblankparams['foo'].present?还有一些其他的方法#returnstrueifnilparams['foo'].

ruby-on-rails - Rails 4,使用 ActiveRecord 的原始查询

目前有没有办法在Rails4.0.0.beta1中使用ActiveRecord执行原始SQL选择查询?我看到ActiveRecord::Base.execute不再存在。正确的做法是什么? 最佳答案 在这里试试这个,选择示例..:query="select...."results=ActiveRecord::Base.connection.execute(query) 关于ruby-on-rails-Rails4,使用ActiveRecord的原始查询,我们在StackOverflow上

ruby-on-rails - ActiveRecord - 查询多态关联

我正在使用多态关联来跟踪我项目中的评论。所有非常直接的东西。我遇到的问题是基于多态关联的查询以及从Comment模型连接回它的所有者。所以...我有一个评论模型classCommenttrueend还有一个论坛主题模式:classForumTopic:commentableend我还有其他几个目前不重要的“可评论”模型。所有这些都有效。我想要做的是找到属于具有指定条件(在本例中,'featured'==true)的ForumTopic的所有评论。当我尝试使用取景器加入模型时:@comments=Comment.find(:all:joins=>:commentable:conditio

ruby - 字符串问题的符号

以下代码失败world=:worldresult='hello'+worldputsresult#=>can'tconvertSymbolintoString以下代码有效world=:worldresult="hello#{world}"putsresult#=>helloworld为什么?使用ruby1.8.7 最佳答案 字符串插值是一个隐式的to_s调用。所以,像这样:result="hello#{expr}"或多或少等同于此:result="hello"+expr.to_s正如karim79所说,符号不是字符串,但符号确实具有